PATENTS 
112025-0538 



IN THE CLAIMS: 

1 1 . (CURRENTLY AMENDED) A distributed software architecture system configured to 

2 implement a routing protocol in a router of a computer network, the system comprising: 

3 a plurality of processors; 

4 a switch fabric interconnecting the processors; and 

5 a plurality of processes each running on a different one of the processors, the 

6 processes including two or more speakers and a protocol routing information base (RIB), 

7 each speaker configured to (i) handle one or more connections to peer routers of the 

8 router, (ii) receive and store routes from those peer routers, (iii) apply inbound policy to 

9 the routes received from the peer routers and (iv) download all routes received from the 

10 peer routers, except those filtered by the inbound policy, to the protocol RIB, the protocol 
n RIB configured to perform a first stage of route selection to compute a set of best routes 
12 from among the routes downloaded from all of the speakers of the router. 

1 2. (ORIGINAL) The system of Claim 1 further comprising a local RIB (loc-RIB) main- 

2 tained by the protocol RIB and configured to store the set of best routes computed by the 

3 protocol RIB. 

1 3. (ORIGINAL) The system of Claim 2 wherein the processes further include a global 

2 RIB configured to maintain a routing table for the router. 

1 4. (ORIGINAL) The system of Claim 3 wherein the protocol RIB is configured to 

2 download the set of best routes from the loc-RIB to the global RIB, the global RIB fur- 

3 ther configured to use the downloaded set of best routes from the loc-RIB, along with 

4 other sets of best routes downloaded from other routing protocols, to perform a second 

5 stage of route selection that computes optimal routes for installation in the routing table. 
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1 5. (ORIGINAL) The system of Claim 4 further comprising one or more line cards con- 

2 nected to the switch fabric, each line card configured to render forwarding decisions on 

3 packets received at the router using a forwarding information base (FIB) constructed 

4 from the optimal routes installed in the routing table. 

1 6. (CURRENTLY AMENDED) The system of Claim 2 wherein the bRIB- protocol RIB 

2 is further configured to upload the set of best routes to the speakers to allow the speakers 

3 to advertise the best routes to the peer routers. 

1 7. (ORIGINAL) The system of Claim 6 wherein each speaker is further configured to ap- 

2 ply outbound policy to the best routes prior to advertising them to the peer routers. 

1 8. (ORIGINAL) The system of Claim 7 wherein each speaker is further configured to ad- 

2 vertise the best routes using update messages. 

1 9. (ORIGINAL) The system of Claim 8 wherein the routing protocol is a Border Gateway 

2 Protocol (BGP) and wherein the protocol RIB is a BGP RIB (bRIB). 

1 10. (ORIGINAL) The system of Claim 1 wherein the routing protocol is a distance vector 

2 routing protocol. 

1 11. (ORIGINAL) A method for implementing a routing protocol in a router of a com- 

2 puter network as a distributed software architecture system, the method comprising the 

3 steps of: 

4 providing a plurality of processors of the router; 

5 interconnecting the processors; 

6 running at least two speakers on at least two first processors of the plurality of 

7 processors, each speaker: 
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8 handling one or more connections to peers of the router, 

9 receiving and storing routes from those peers, 

10 applying inbound policy to the routes received from the peers, and 

11 running a protocol routing information base (RIB) on a second processor of the 



12 plurality of processors, each speaker downloading all routes received from the peers, ex- 
o cept those filtered by the inbound policy, to the protocol RIB, the protocol RIB perform- 
14 ing a first stage of route selection to compute best routes from among the routes down- 
is loaded from all of the speakers of the router. 

1 12. (ORIGINAL) The method of Claim 1 1 further comprising the steps of: 

2 maintaining a local RIB (loc-RIB) at the protocol RIB; and 

3 storing the best routes computed by the protocol RIB in the loc-RIB. 

1 13. (ORIGINAL) The method of Claim 12 further comprising the step of running a 

2 global RIB on a third processor of the plurality of processors, the global RIB maintaining 

3 a routing table for the router. 

1 14. (ORIGINAL) The method of Claim 13 wherein the second and third processors are 

2 the same processor. 

1 15. (ORIGINAL) The method of Claim 13 further comprising the steps of: 

2 downloading the best routes from the loc-RIB to the global RIB; 

3 performing a second stage of route selection at the global RIB using the down- 

4 loaded best routes from the loc-RIB, along with other sets of best routes downloaded 

5 from other routing protocols, the second stage of route selection computing optimal 

6 routes for installation in the routing table. 

1 16. (ORIGINAL) The method of Claim 1 5 further comprising the steps of: 

2 interconnecting one or more line cards to the plurality of processors; 
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constructing a forwarding information base (FIB) at each line card, the FIB con- 
structed from the optimal routes installed in the routing table; and 

rendering forwarding decisions on packets received at each line card using the 

FIB. 

17. (CURRENTLY AMENDED) The method of Claim 12 further comprising the steps 
of: 

uploading the best routes from the bR4B -protocol RIB to each speaker; 
applying outbound policy to the uploaded best routes; and 
advertising resulting best routes to the peers. 

18. (ORIGINAL) Apparatus adapted to implement a Border Gateway Protocol (BGP) 
routing protocol in a router of a computer network as a distributed software architecture 
system, the apparatus comprising: 

means for running a BGP speaker on a first processor of a plurality of intercon- 
nected processors, the BGP speaker including: 

means for handling one or more connections to peers of the router, 

means for receiving and storing routes from those peers, 

means for applying inbound policy to the routes received from the peers, 

and 

means for running a BGP routing information base (bRIB) on a second processor 
of the plurality of interconnected processors, the BGP speaker further including means 
for downloading all routes received from the peers, except those filtered by the inbound 
policy, to the bRIB, the bRIB including means for performing a first stage of route selec- 
tion to compute best routes from among the routes downloaded from the BGP speaker. 

19. (ORIGINAL) The apparatus of Claim 18 further comprising: 

means for maintaining a local RIB (loc-RIB) at the bRIB; and 

means for storing the best routes computed by the bRIB in the loc-RIB. 
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1 20. (ORIGINAL) A computer readable medium containing executable program instruc- 

2 tions for implementing a routing protocol in a router of a computer network as a distrib- 

3 uted software architecture system, the executable program instructions comprising pro- 

4 gram instructions for: 

5 running at least two speakers on at least two first processors of a plurality of in- 

6 terconnected processors, each speaker: 

7 handling one or more connections to peers of the router, 

8 receiving and storing routes from those peers, 

9 applying inbound policy to the routes received from the peers, and 

10 running a protocol routing information base (RIB) on a second processor of the 



1 1 plurality of interconnected processors, each speaker downloading all routes received from 

12 the peers, except those filtered by the inbound policy, to the protocol RIB, the protocol 

13 RIB performing a first stage of route selection to compute best routes from among the 

14 routes downloaded from all of the speakers of the router. 



1 21 . (ORIGINAL) The computer readable medium of Claim 20 further comprising pro- 

2 gram instructions for: 

3 maintaining a local RIB (loc-RIB) at the protocol RIB; and 

4 storing the best routes computed by the protocol RIB in the loc-RIB. 
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